{extend name="layouts/main-layui-vue-index" /}
{block name="title"}{__block__}{/block}
{block name="header"}{/block}
{block name="beforeDiv"}{/block}
{block name="appDiv"}
<lay-container fluid="true" class="role-box">
    <lay-card>
        <lay-form style="margin-top: 10px">
            <lay-row>
                <lay-col :md="5">
                    <lay-form-item label="角色名称" label-width="80">
                        <lay-input v-model="searchQuery.roleName" placeholder="请输入" size="sm" :allow-clear="true" style="width: 98%"></lay-input>
                    </lay-form-item>
                </lay-col>
                <lay-col :md="5">
                    <lay-form-item label="角色标识" label-width="80">
                        <lay-input v-model="searchQuery.identifying" placeholder="请输入"
                                size="sm" :allow-clear="true" style="width: 98%"></lay-input>
                    </lay-form-item>
                </lay-col>
                <lay-col :md="5">
                    <lay-form-item label="备注" label-width="80">
                        <lay-input v-model="searchQuery.mark" placeholder="请输入"
                                size="sm" :allow-clear="true" style="width: 98%"></lay-input>
                    </lay-form-item>
                </lay-col>
                <lay-col :md="5">
                    <lay-form-item label-width="20">
                        <lay-button style="margin-left: 20px" type="normal" size="sm" @click="toSearch">
                            查询
                        </lay-button>
                        <lay-button size="sm" @click="toReset"> 重置</lay-button>
                    </lay-form-item>
                </lay-col>
            </lay-row>
        </lay-form>
    </lay-card>
    <!-- table -->
    <div class="table-box">
        <lay-table class="table-style" :page="page" :columns="columns" :loading="loading"
                :default-toolbar="true" :data-source="dataSource" v-model:selected-keys="selectedKeys"
                @change="change" @sort-change="sortChange" :height="tableHeight">
            <template v-slot:toolbar>
                <lay-button size="sm" type="primary" @click="changeVisible11('新增', null)">
                    <lay-icon class="layui-icon-addition"></lay-icon>
                    新增
                </lay-button>
                <lay-button size="sm" @click="toRemove">
                    <lay-icon class="layui-icon-delete"></lay-icon>
                    删除
                </lay-button>
            </template>
            <template v-slot:operator="{ row }">
                <lay-button size="xs" border="green" border-style="dashed" @click="changeVisible11('编辑', row)">编辑</lay-button>
                <lay-button size="xs" border="blue" border-style="dashed" @click="toPrivileges(row)">分配权限</lay-button>
                <lay-popconfirm content="确定要删除此角色吗?" @confirm="confirm" @cancel="cancel">
                    <lay-button size="xs" border="red" border-style="dashed">删除</lay-button>
                </lay-popconfirm>
            </template>
        </lay-table>
    </div>

    <lay-layer v-model="visible11" :title="title" :area="['500px', '370px']">
        <div style="padding: 20px">
            <lay-form :model="model11" ref="layFormRef11" required>
                <lay-form-item label="角色名称" prop="name">
                    <lay-input v-model="model11.name"></lay-input>
                </lay-form-item>
                <lay-form-item label="角色标识" prop="flage">
                    <lay-input v-model="model11.flage"></lay-input>
                </lay-form-item>
                <lay-form-item label="描述" prop="remark">
                    <lay-textarea placeholder="请输入描述" v-model="model11.remark"></lay-textarea>
                </lay-form-item>
            </lay-form>
            <div style="width: 100%; text-align: center">
                <lay-button size="sm" type="primary" @click="toSubmit">保存</lay-button>
                <lay-button size="sm" @click="toCancel">取消</lay-button>
            </div>
        </div>
    </lay-layer>

    <lay-layer v-model="visible22" title="分配权限" :area="['500px', '450px']">
        <div style="height: 320px; overflow: auto">
            <lay-tree style="margin-left: 40px" :tail-node-icon="false" :data="data2" :show-checkbox="showCheckbox2" v-model:checked-keys="checkedKeys2">
                <template #title="{ data }">
                    <lay-icon :class="data.icon"></lay-icon>
                    {{ data.title }}
                </template>
            </lay-tree>
        </div>
        <lay-line></lay-line>
        <div style="width: 90%; text-align: right">
            <lay-button size="sm" type="primary" @click="toSubmit">保存</lay-button>
            <lay-button size="sm" @click="toCancel">取消</lay-button>
        </div>
    </lay-layer>
</lay-container>
{/block}
{block name="afterDiv"}

<script setup lang="ts">
    const searchQuery = ref({
        roleName: '',
        identifying: '',
        mark: ''
    })

    function toReset() {
        searchQuery.value = {
            roleName: '',
            identifying: '',
            mark: ''
        }
    }

    function toSearch() {
        page.current = 1
        change(page)
    }

    const loading = ref(false)
    const selectedKeys = ref()
    const page = reactive({current: 1, limit: 10, total: 4})
    const columns = ref([
        {title: '选项', width: '55px', type: 'checkbox', fixed: 'left'},
        {title: '编号', width: '80px', key: 'id', fixed: 'left', sort: 'desc'},
        {title: '角色名称', width: '80px', key: 'name', sort: 'desc'},
        {title: '角色标识', width: '80px', key: 'flage', sort: 'desc'},
        {title: '备注', width: '260px', key: 'remark', sort: 'desc'},
        {title: '创建时间', width: '120px', key: 'joinTime', sort: 'desc'},
        {
            title: '操作',
            width: '150px',
            customSlot: 'operator',
            key: 'operator',
            fixed: 'right'
        }
    ])
    const change = (page) => {
        loading.value = true
        setTimeout(() => {
            loading.value = false
        }, 1000)
    }
    const sortChange = (key, sort) => {
        layer.msg(`字段${key} - 排序${sort}, 你可以利用 sort-change 实现服务端排序`)
    }
    const dataSource = ref([
        {
            id: '1',
            name: '管理员',
            remark: '花开堪折直须折,莫待无花空折枝.',
            joinTime: '2022-02-09 16:35:07',
            flage: 'admin'
        },
        {
            id: '2',
            name: '普通用户',
            remark: '花开堪折直须折,莫待无花空折枝.',
            joinTime: '2022-02-09 16:35:07',
            flage: 'user'
        },
        {
            id: '3',
            name: '游客',
            remark: '花开堪折直须折,莫待无花空折枝.',
            joinTime: '2022-02-09 16:35:07',
            flage: 'guser'
        }
    ])
    const changeStatus = (isChecked, row) => {
        dataSource.value.forEach((item) => {
            if (item.id === row.id) {
                layer.msg('Success', {icon: 1}, () => {
                    item.flage = isChecked
                })
            }
        })
    }
    const remove = () => {
        layer.msg(selectedKeys.value, {area: '50%'})
    }
    const loadDataSource = (page, pageSize) => {
        var response = []
        var startIndex = (page - 1) * pageSize + 1
        var endIndex = page * pageSize
        for (var i = startIndex; i <= endIndex; i++) {
            response.push({
                id: `${i}`,
                name: `用户${i}`,
                flage: 'user',
                remark: '花开堪折直须折,莫待无花空折枝.',
                joinTime: '2022-02-09 16:35:07'
            })
        }
        return response
    }
    const model11 = ref({
        name: '',
        flage: '',
        remark: ''
    })
    const layFormRef11 = ref()
    const visible11 = ref(false)

    const title = ref('新增')
    const changeVisible11 = (text, row) => {
        title.value = text
        if (row != null) {
            let info = JSON.parse(JSON.stringify(row))
            model11.value = info
        } else {
            model11.value = {
                name: '',
                flage: '',
                remark: ''
            }
        }
        visible11.value = !visible11.value
    }
    const submit11 = function () {
        layFormRef11.value.validate((isValidate, model, errors) => {
            layer.open({
                type: 1,
                title: '表单提交结果',
                content: `<div style="padding: 10px"><p>是否通过 : ${isValidate}</p> <p>表单数据 : ${JSON.stringify(
                    model
                )} </p> <p>错误信息 : ${JSON.stringify(errors)}</p></div>`,
                shade: false,
                isHtmlFragment: true,
                btn: [
                    {
                        text: '确认',
                        callback(index) {
                            layer.close(index)
                        }
                    }
                ],
                area: '500px'
            })
        })
    }
    // 清除校验
    const clearValidate11 = function () {
        layFormRef11.value.clearValidate()
    }
    // 重置表单
    const reset11 = function () {
        layFormRef11.value.reset()
    }

    function toRemove() {
        if (selectedKeys.value.length == 0) {
            layer.msg('您未选择数据，请先选择要删除的数据', {icon: 3, time: 2000})
            return
        }
        layer.confirm('您将删除所有选中的数据？', {
            title: '提示',
            btn: [
                {
                    text: '确定',
                    callback: (id) => {
                        layer.msg('您已成功删除')
                        layer.close(id)
                    }
                },
                {
                    text: '取消',
                    callback: (id) => {
                        layer.msg('您已取消操作')
                        layer.close(id)
                    }
                }
            ]
        })
    }

    function toSubmit() {
        layer.msg('保存成功！', {icon: 1, time: 1000})
        visible11.value = false
        visible22.value = false
    }

    function toCancel() {
        visible11.value = false
        visible22.value = false
    }

    function confirm() {
        layer.msg('您已成功删除')
    }

    function cancel() {
        layer.msg('您已取消操作')
    }

    const visible22 = ref(false)
    const checkedKeys2 = ref([])
    const showCheckbox2 = ref(true)

    const data2 = ref([
        {
            icon: 'layui-icon-home',

            title: '工作空间',
            id: 1,
            checked: true,
            spread: true,
            children: [
                {
                    title: '工作台',
                    icon: 'layui-icon-util',
                    id: 3
                },
                {
                    title: '控制台',
                    icon: 'layui-icon-engine',
                    id: 4,
                    spread: true
                },
                {
                    title: '分析页',
                    id: 20,
                    icon: 'layui-icon-chart-screen'
                },
                {
                    title: '监控页',
                    id: 21,
                    icon: 'layui-icon-find-fill'
                }
            ]
        },
        {
            title: '表单页面',
            icon: 'layui-icon-table',
            id: 2,
            spread: true,
            children: [
                {
                    title: '基础表单',
                    icon: 'layui-icon-form',
                    id: 5,
                    spread: true
                },
                {
                    title: '复杂表单',
                    icon: 'layui-icon-form',
                    id: 6
                }
            ]
        },
        {
            title: '个人中心',
            icon: 'layui-icon-slider',
            id: 16,
            children: [
                {
                    icon: 'layui-icon-username',
                    title: '我的资料',
                    id: 17,
                    fixed: true
                },
                {
                    title: '我的消息',
                    icon: 'layui-icon-email',
                    id: 27
                }
            ]
        },
        {
            title: '系统管理',
            icon: 'layui-icon-set',
            id: 19,
            children: [
                {
                    icon: 'layui-icon-user',
                    title: '用户管理',
                    id: 25,
                    fixed: true
                },
                {
                    title: '角色管理',
                    icon: 'layui-icon-group',
                    id: 29
                },
                {
                    title: '机构管理',
                    icon: 'layui-icon-transfer',
                    id: 29
                }
            ]
        }
    ])

    function toPrivileges(row) {
        visible22.value = true
    }

    const tableHeight=(pageHeight-153)+'px';
</script>
<script>
    vue_data = {};
    vue_setup = {
        toPrivileges,data2,showCheckbox2,checkedKeys2,visible22,cancel,confirm,toCancel,toSubmit,toRemove,reset11,
        clearValidate11,submit11,changeVisible11,title,visible11,layFormRef11,model11,loadDataSource,remove,tableHeight,
        changeStatus,dataSource,sortChange,change,columns,page,selectedKeys,loading,toSearch,toReset,searchQuery
    };
    methods = {
        onLoad() {
            console.log('页面初始化请求数据并加载')
        },
    };
    watch = {};
    computed = {};
    mounted = function () {
        this.onLoad();
    };
    updated = function () {
    };

</script>
<style scoped>
    .role-box {
        margin-top: 10px;
        box-sizing: border-box;
        overflow: hidden;
    }

    .top-search {
        margin-top: 10px;
        padding: 10px;
        height: 40px;
        border-radius: 4px;
        background-color: #fff;
    }

    .table-box {
        margin-top: 10px;
        padding: 10px;
        width: 100%;
        border-radius: 4px;
        box-sizing: border-box;
        background-color: #fff;
    }

    .search-input {
        display: inline-block;
        width: 98%;
        margin-right: 10px;
    }

    .table-style {
        margin-top: 10px;
    }

    .isChecked {
        display: inline-block;
        background-color: #e8f1ff;
        color: red;
    }
</style>

{/block}
{block name="constApp"}{__block__}{/block}
{block name="plugins"}{/block}
{block name="mountApp"}{__block__}{/block}